//入口函数
$(function () {
    //需求1：获取用户信息渲染头像
    getUserInfo()

    //需求2：退出
    $('#logout').on('click',function(){
        //layui里面的询问框，点击确定才会执行回调函数里面的代码
       layer.confirm('确认退出登录吗?', {
           icon: 3,
           title: '提示'
       }, function (index) {
           //do something
        //    销毁token，跳转到登录页
        localStorage.removeItem('token')
        location.href='/login.html'
        // 自带的代码，关闭询问框
        layer.close(index);
       });
    })
})

//获取用户信息渲染头像封装成函数
//要求：必须设置为全局函数，不是局部函数
function getUserInfo() {
    //发送axios请求
    axios({
        //请求方式是GET，可以省略
        //method:'GET'
        url: '/my/userinfo',
        //通过请求头设置token身份认证
        headers: {
            Authorization: localStorage.getItem('token')
        }
    }).then(res => {
        // console.log(res.data.data);
        //判断
        if (res.data.status !== 0) {
            return layui.layer.msg(res.data.message)
        }
        //渲染
        renderAvatar(res.data.data)
    })
}

//渲染用户信息和头像
function renderAvatar(user) {
    // 渲染欢迎:如果有nickname优先渲染nickname，没有nickname渲染username
    let name = user.nickname || user.username
    $('.welcome').html('欢迎&nbsp;' + name)
    //处理头像：如果有图片头像渲染图片头像，否则渲染文字头像
    if (user.user_pic !== null) {
        //如果有图片头像,渲染图片头像-隐藏文字头像，显示图片头像
        $('.text-avatar').hide()
        $('.layui-nav-img').show().attr('src', user.user_pic)

    } else {
        //没有图片头像，就渲染文字头像-隐藏图片头像，显示文字头像
        $('.layui-nav-img').hide()
        //渲染name中的第一个单词字符，而且大写
        let first = name[0].toUpperCase()
        $('.text-avatar').show().html(first)
    }
}







